<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>

    <#include "../common/link.ftl">

    <!--引入验证插件的样式文件-->
    <link rel="stylesheet" href="/js/plugins/bootstrap-validator/css/bootstrapValidator.min.css">
    <!--引入验证插件的js文件-->
    <script type="text/javascript" src="/js/plugins/bootstrap-validator/js/bootstrapValidator.min.js"></script>
    <!--中文语言库-->
    <script type="text/javascript" src="/js/plugins/bootstrap-validator/js/language/zh_CN.js"></script>


</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include "../common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee">
    <#include "../common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id" id="eId">
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="name" name="name" value="${(employee.name)!}"
                                   <#if (employee.name)??>readonly</#if> placeholder="请输入用户名">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="password" class="col-sm-2 control-label">密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email" value="${(employee.email)!}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age" value="${(employee.age)!}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <#list depts as d>
                                    <option value="${d.id}">${d.name}</option>
                                </#list>
                                <script>
                                    $("#dept").val(${(employee.dept.id)!});
                                </script>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="admindiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox" value="true">
                            <#if (employee.admin)?? && employee.admin>
                                <script>
                                    $("#admin").prop("checked", true);
                                </script>
                            </#if>
                        </div>
                    </div>
                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#list roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#list (roleList)! as role>
                                        <option value="${(role.id)!}">${(role.name)!}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="submitBtn" type="submit" class="btn btn-primary">保存</button>
                            <button type="reset" class="btn btn-danger" id="resetId">重置</button>
                        </div>
                    </div>

                </form>

            </div>
        </section>
    </div>
    <#include "../common/footer.ftl">
</div>
<script>
    function moveSelected(src_select,des_select){
        var src = $("." + src_select + ">option");
        var des = $("." + des_select);
        src.each(function (i,tmp){
            var flag = $(tmp).prop("selected");
            if (flag){
                des.append($(tmp));
            }
        });
    }

    function moveAll(src_select,des_select){
        var src = $("." + src_select + ">option").prop("selected",true);
        $("." + des_select).append(src);
    }


    $(function (){

        var role;
        $("#admin").click(function (){
            var flag = $("#admin").prop("checked");
            if (flag){
                role = $("#role").detach();
            }else {
                $("#admindiv").after(role);
            }
        });

        var isAdmin = $("#admin").prop("checked");
        if (isAdmin){
            role = $("#role").detach();
        }

        //去重
        /* 左边：allRoles  右边：selfRoles*/
        var right = $(".selfRoles>option");
        var array = [];
        right.each(function (i,tmp){
           array.push($(tmp).val());

        });

        var left = $(".allRoles>option");
        left.each(function (i,tmp){
            for (var j=0;j<array.length;j++){
                if ($(tmp).val() == array[j]){
                    $(tmp).remove();
                    break;
                }
            }
        });



        $("#resetId").click(function (){
            if ($("#eId").val() != null){
                window.location.href = "/employee/input.do?id="+$("#eId").val();
            }
        });


        //表单验证
        $('#editForm').bootstrapValidator({
            feedbackIcons: {
                valid: 'glyphicon glyphicon-ok',
                invalid: 'glyphicon glyphicon-remove',
                validating: 'glyphicon glyphicon-refresh'
            },
            fields: {
                <#if !employee??>
                name: {
                    validators: {
                        notEmpty: {
                            message: '用户名不能为空'
                        },
                        remote: { //远程验证
                            type: 'POST', //请求方式
                            url: '/employee/checkName.do', //请求地址
                            // data: function() {  //自定义提交参数，默认只会提交当前用户名input的参数
                            //     return {
                            //         id: $('[name="id"]').val(),
                            //         name: $('[name="name"]').val()
                            //     };
                            // },
                            message: '用户名已经存在', //验证不通过时的提示信息
                            delay: 2000 //输入内容2秒后发请求
                        },
                        stringLength: {
                            min: 2,
                            max: 32,
                            message: '用户名需要在8到32位之间'
                        },
                        regexp: {
                            regexp: /^[a-zA-Z0-9_\.]+$/,
                            message: '用户名中只能包含字母、数字及"_"、"."'
                        },
                        different: {
                            field: 'password',
                            message: '用户名不能和密码相同'
                        }
                    }
                },
                </#if>
                email: {
                    validators: {
                        notEmpty: {
                            message: '邮箱不能为空'
                        },
                        emailAddress: {
                            message: '请输入正确格式的email，如：xxx@163.com'
                        }
                    }
                },
                password: {
                    validators: {
                        notEmpty: {
                            message: '密码不能为空'
                        },
                        identical: {
                            field: 'repassword',
                            message: '两次输入密码不一致'
                        },
                        different: {
                            field: '',
                            message: '用户名和密码不能相同'
                        }
                    }
                },
                repassword: {
                    validators: {
                        notEmpty: {
                            message: '重复密码不能为空'
                        },
                        identical: {
                            field: 'password',
                            message: '两次输入密码不一致'
                        },
                        different: {
                            field: '',
                            message: '用户名和重复密码不能相同'
                        }
                    }
                },
                age: {
                    validators:{
                        notEmpty: {
                            message: '年龄不能为空'
                        },
                        between: {
                            min: 1,
                            max: 120
                        }
                    }
                }
            }
        }).on('success.form.bv',function (e){
            //1. 按钮必须设置成submit
            //2. 禁止表单正常提交方式
            e.preventDefault();
            $(".selfRoles>option").prop("selected",true);
            //使用异步提交方式
            $("#editForm").ajaxSubmit(function (data){
                if (data.flag){
                    window.location.href='/employee/list.do';
                }else {
                    $.messager.popup(data.msg);
                }
            });
        });

    });
</script>
</body>
</html>
